//
// This file is part of the aMule Project.
//
// Copyright (c) 2004-2006 Angel Vidal (Kry) ( kry@amule.org )
// Copyright (c) 2004-2006 aMule Team ( admin@amule.org / http://www.amule.org )
// Copyright (c) 2003 Barry Dunne (http://www.emule-project.net)
//
// Any parts of this program derived from the xMule, lMule or eMule project,
// or contributed by third-party developers are copyrighted by their
// respective authors.
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
// 
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301, USA
//

// Note To Mods //
/*
Please do not change anything here and release it..
There is going to be a new forum created just for the Kademlia side of the client..
If you feel there is an error or a way to improve something, please
post it in the forum first and let us look at it.. If it is a real improvement,
it will be added to the offical client.. Changing something without knowing
what all it does can cause great harm to the network if released in mass form..
Any mod that changes anything within the Kademlia side will not be allowed to advertise
there client on the eMule forum..
*/

#ifndef __SEARCH_H__
#define __SEARCH_H__

#include "SearchManager.h"
#include "Maps.h"
#include "UInt128.h"
#include "ByteIO.h"
#include "Kademlia.h"

extern "C" {
#include "KadClog.h"
}
class CMemFile;
class CTag;

////////////////////////////////////////
namespace std {
////////////////////////////////////////

class SearchResultCallback;


class CSearch
{
	friend class CSearchManager;

public:
	uint32 getSearchID() const {return m_searchID;}
	uint32 getSearchTypes() const {return m_type;}
	void setSearchID( uint32 val ) {m_searchID = val;}
	void setSearchTypes( uint32 val ) {m_type = val;}
	void setTargetID( CUInt128 val ) {m_target = val;}
  void setNotesToStore(SimpleTagList &notesToStore) { m_notesToStore = notesToStore; }
  void setSearchResultCallback(SearchResultCallback *searchResultCallback);

	uint32 getAnswers() const {
		if(bio2 == NULL) {
			return m_answers;
		} else if(bio3 == NULL) {
			return m_answers/2;
		} else {
			return m_answers/3;
			}
		}
	uint32 getKadPacketSent() const {return m_kadPacketSent;}
	uint32 getRequestAnswer() const {return m_totalRequestAnswers;}
	void storePacket();

	CUInt128 m_keywordPublish; //Need to make this private...
	byte packet1[1024*50];
	byte packet2[1024*50];
	byte packet3[1024*50];
	CByteIO *bio1;
	CByteIO *bio2;
	CByteIO *bio3;
	//const wxString& getFileName(void) const { return m_fileName; }
	//void setFileName(const wxString& fileName) { m_fileName = fileName; }
	CUInt128 getTarget(void) const {return m_target;}
	void addFileID(const CUInt128& id);
	void PreparePacket(void);
	//void PreparePacketForTags( CByteIO* packet, CKnownFile* file );
	bool Stoping(void) const {return m_stoping;}
	uint32 getNodeLoad() const;
	uint32 getNodeLoadResonse() const {return m_totalLoadResponses;}
	uint32 getNodeLoadTotal() const {return m_totalLoad;}
	void updateNodeLoad( uint8 load ){ m_totalLoad += load; m_totalLoadResponses++; }
  void printSearchStats(const char *prefix) const;
  const char * typeToString() const;
  void processPublishNoteResponse();


	enum
	{
		NODE,
		NODECOMPLETE,
		FILE,
		KEYWORD,
		NOTES,
		STOREFILE,
		STOREKEYWORD,
		STORENOTES,
		FINDBUDDY,
		FINDSOURCE
	};

	CSearch();
	~CSearch();

	//Variables
	CKademlia* parentInstance;

private:
	void go(void);
	void processResponse(uint32 fromIP, uint16 fromPort, ContactList *results);
  void processResult(const SimpleTagList &tagList);
	void jumpStart(void);
	void sendFindValue(const CUInt128 &check, uint32 ip, uint16 port);
	void prepareToStop(void);

	bool		m_stoping;
	time_t		m_created;
	uint32		m_type;
	uint32		m_answers;
	uint32		m_totalRequestAnswers;
	uint32		m_kadPacketSent; //Used for gui reasons.. May not be needed later..
	uint32		m_totalLoad;
	uint32		m_totalLoadResponses;
	uint32		m_lastResponse;

	uint32		m_searchID;
	CUInt128	m_target;
	CMemFile*	m_searchTerms;
	UIntList	m_fileIDs;

	ContactMap	m_possible;
	ContactMap	m_tried;
	ContactMap	m_responded;
	ContactMap	m_best;
	ContactList	m_delete;
	ContactMap	m_inUse;

  // Notes to start during publish notes operation
  SimpleTagList m_notesToStore;

  // Callback for when we receive a search result
  SearchResultCallback *m_searchResultCallback;

  // Collect some stats about how many operations are performed for this search
  uint32 m_kadReqSentCount;
  uint32 m_kadResRcvdCount;
  uint32 m_kadNoteSrcReqSentCount;
  uint32 m_kadNoteSrcResRcvdCount;
  uint32 m_kadNotePubReqSentCount;
  uint32 m_kadNotePubResRcvdCount;


  static uint32 g_searchIdCounter;
};

} // End namespace

#endif //__SEARCH_H__
